#
# @lc app=leetcode.cn id=2260 lang=python3
#
# [2260] 必须拿起的最小连续卡牌数
#
'''
给你一个整数数组 cards ，其中 cards[i] 表示第 i 张卡牌的 值 。如果两张卡牌的值相同，则认为这一对卡牌 匹配 。

返回你必须拿起的最小连续卡牌数，以使在拿起的卡牌中有一对匹配的卡牌。如果无法得到一对匹配的卡牌，返回 -1 。

 

示例 1：

输入：cards = [3,4,2,3,4,7]
输出：4
解释：拿起卡牌 [3,4,2,3] 将会包含一对值为 3 的匹配卡牌。注意，拿起 [4,2,3,4] 也是最优方案。
示例 2：

输入：cards = [1,0,5,3]
输出：-1
解释：无法找出含一对匹配卡牌的一组连续卡牌。
'''
# @lc code=start
from cmath import inf
from collections import defaultdict
from typing import List


class Solution:
    def minimumCardPickup(self, cards: List[int]) -> int:
        ans = inf
        cnt = defaultdict(int)
        for i,x in enumerate(cards):
            if x in cnt:
                ans = min(ans,i - cnt[x] + 1)
            cnt[x] = i
        return ans if ans != inf else -1
# @lc code=end

